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CREDIT-BASED ADAPTIVE FLOW CONTROL FOR MULTI-STAGE MULTI- 
DIMENSIONAL SWITCHING ARCHITECTURE 

5 

DF.<qC!RTPTION 
TFinHNTCAT. FTET.D OF THE INVENTION 

The present invention relates generally to switch 
10 architecture, and more particularly to credit -based 

adaptive traffic flow control for a multi-stage multi- 
dimensional switch. 



RArTOPOTTND OF TRE INVENTION 

15 

Conventional multi-stage, multi-dimensional switching 
architecture typically includes three stages. The first 
and third stages are the buffering stages while the second 
stage acts as a bufferless crossbar switch node. Each 
20 stage includes an array of switching element and each 
element includes either a queuing processor or an 
arbitration processor which makes decisions to route 
arriving data packets from any input port to any output 
port . 

25 Because of its easy scalability and expandability, the 

multi-stage, mult i -dimensional switching technique has been 
acceptable in many types of switched architecture including 
many data switch applications. On the other hand, 
disadvantages of such switching techniques include complex 

30 algorithms required for employing the switch resulting in a 
substantial switching latency. As generally recognized by 
those skilled in the art, the routing algorithms required 
in the multi-stage, mult i -dimensional switch architecture 
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are complex. Further, such routing algorithms become 
exponentially more complex with increasing number of 
switching elements within an architecture. The more 
complex algorithms require more complex internal data 
5 structures in the bidding stage (first stage) and the 
granting stage (second stage) , additional switch tag 
fields, more complex bidding process, and ultimately longer 
time for a grant /reject response to a bid to turn around. 
The increasing number of switching elements within the 

10 architecture also creates greater potential contention for 
any bidding effort. These disadvantages associated with 
the multi-stage, mult i -dimensional switch architecture have 
prompted a need for additional research in the field. 

One example of the bottlenecks in the complex routing 

15 algorithms is that data packets from many or all input 
ports of the first -stage may arrive at a specific input 
port of the second- stage at the same time, resulting in a 
severe contention consequence. An active bidding and 
granting procedure is considered as a primary solution for 

20 this problem. Current research activities mainly 

concentrate on techniques for improving the active bidding 
and granting process, and pushing the design to the limit 
of state-of-the-art fabrication technology. However, many 
timing constraints resulting in bidding and granting logic 

25 as well as interfaces between these two stages make active 
bidding and granting logic hard to implement, and make the 
grant response to the bid very hard to happen within a 
reasonable time period. This problem becomes even worse 
when more and more switch elements are involved. 

3 0 Therefore, it is highly desirable to have a self -adjustable 
flow control technique for the multi-stage, multi- 
dimensional switching architecture which does not require 
any specific data fields from the upstream switch element, 
and of which the complexity is not related to the number of 

35 increasing switching elements within a switch architecture. 
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Switches providing interconnections between nodes on a 
network invariably include some type of a traffic flow 
control technique. The credit-based flow control technique 
is one such traffic flow control technique. The credit- 
5 based flow control technique currently available in the 

market and generally known to those skilled in the art are 
typically designed for flow control between two switch 
elements, referred to as hubs, at a network level on a one- 
to-one basis. The hub-to-hub, credit-based, flow control 

10 usually resolves congestion earlier as compared to the end- 
to-end flow control techniques. Although different 
versions of this technique have been adopted in many switch 
products, the credit -based flow control technique has not 
yet been applied inside a switching hub. 

15 Filtering techniques are generally known and have been 

applied in various applications. For example, an adaptive 
filtering technique has been applied to radar antenna 
arrays. Additionally, one-dimensional applications of 
adaptive filtering may be found in the field of electronics 

20 and also in the field of data routing known as adaptive 

directory routing. Furthermore, multi-dimensional adaptive 
filtering is currently being applied to digital image 
processing applications. Generally, however, the adaptive 
filtering technique has not yet been applied to a data 

25 switch design. Moreover, multi-dimensional filtering has 
not been applied to any type of a network design. 

.qiTMMA^Y OF TPTF! TNVKNTTON 

3 0 The present invention combines credit -based flow 

control, multi-stage multi-dimensional switching, and 
adaptive filtering together and seamlessly applies them to 
a mesh of switching elements. More particularly, the 
present invention adopts a mult i -dimensional adaptive 

35 filtering mechanism into a multi-stage, multi-dimensional. 
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switching architecture. 

The adaptive filtering process in one embodiment of 
the present invention is accomplished by adaptively 
adjusting a "threshold" array or grant credit. When 
5 employed; the adaptive filtering process of the present 

invention drives the statistical properties of the network 
to conform to nearly uniform probability distribution. 

In accordance with the goals of the present invention, 
there is provided a novel multi-stage, multi-dimensional, 

10 credit -based adaptive flow control method. In one 

embodiment, each crossconnect element of the second stage 
accumulates the statistics of data packet arrivals and 
departures on per-port based, and notifies the first stage 
with a single token bit whenever the second stage receives 

15 a data packet from a specific output port, for example, 
output port #i, of the first-stage, and departs it. The 
value of an up/down counter for this specific output port 
is maintained until the data packet is departed from the 
second stage. 

2 0 The first stage switch elements update the grant 

credits associated with the output port #i when notified by 
the token bit from the second stage, and then waits for 
next data packet arrival from external nodes. The grant 
credit updates generally apply to three integrator blocks 
25 associated with three neighboring output ports of the first 
stage, subtracting one credit from the output port which 
has just sent out a data packet to the second stage, and 
simultaneously adding one credit to two of its next 
neighboring integrator blocks . 

3 0 The first stage switch elements use the updated grant 

credit information to decide to which second stage switch 
element, i.e., crossconnect element, the next data packet 
should be sent. The advantage of doing so is that the 
first stage knows where to route an incoming packet prior 
35 to its arrival so that the active bidding alternative. 
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i,e., the first stage sends a bid to the second stage to 
request an access grant, is no longer needed. This leads 
to relaxing many stringent design requirements, and 
therefore, larger network meshes can be built as a result. 
5 Upon every arrival at the first stage, the credits 

with all the output ports in each first stage element may 
be scanned in the ascending order from 0 to N-1 to find a 
maximum. The data packet is then sent via the output 
element with the maximum credit to the second stage. 

10 Another aspect of the present invention includes a 

simple credit feedback loop embedded into the data stream 
from the second stage to the third stage, and the third 
stage relays the credit token back to the first stage. 
Further, the first stage and third stage may be on the same 

15 chip or the same board. 

Yet another aspect of the present invention includes a 
plurality of interconnected digital logic blocks including 
second stage statistic blocks, first stage integrator 
blocks, and first stage threshold blocks. The second stage 

20 statistics blocks are arranged to maintain the real-time 
statistics of data packet arrivals and departures. The 
first stage integrator blocks receive logic values from the 
statistics blocks and update grant credits accordingly. 
The first stage threshold blocks look for an output port 

2 5 with maximum grant credits and forward the packets via the 

output port to second stage where feedback tokens are then 
generated and sent back to the first stage. 

Further features and advantages of the present 
invention as well as the structure and operation of various 

3 0 embodiments of the present invention are described in 

detail below with reference to the accompanying drawings. 
In the drawings, like reference numbers indicate identical 
or functionally similar elements. 

35 RRTEF DESCRIPTION OF THE DRAWING.q 
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The embodiments of the present invention will now be 
described, by way of example only, with reference to the 
accompanying drawings in which: 
5 Figure 1 shows a three-stage mult i -dimensional switch 

architecture to which the method of the present invention 
is applied; 

Figure 2 is a diagram illustrating the structure of 
credit -based adaptive flow control logic inside each switch 
10 element in Stage-1 and inside each crossconnect element in 
Stage-2 in one embodiment of the present invention; 

Figure 3 shows the upper boundary structure of the 
credit-based adaptive flow control logic in one embodiment 
of the present invention; 
15 Figure 4 shows the bottom boundary structure of the 

credit -based adaptive flow control logic in one embodiment 
of the present invention; 

Figure 5 is a diagram illustrating a detailed internal 
logic flow of a two-port first stage switch element in one 

2 0 embodiment of the present invention; and 

Figure 6 is a diagram illustrating a detailed internal 
logic flow of a second stage crossconnect element in one 
embodiment of the present invention. 

25 

nF.TATT.F.D DF.fiCRIPTTQN OF THF TNVENTTON 

Figure 1 shows the architecture of a three-stage 
multi-dimensional switch fabric 100 in one embodiment of 

3 0 the present invention. Briefly, a switching element is a 

basic building block of a switch and generally includes 
devices for providing inputs and outputs. As generally 
known to those skilled in the art of network switches, a 
switching fabric refers to an interconnection of switching 
35 elements. As shown in Figure 1, the switch architecture 
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10 0 of the present invention includes at least three 
stages. The first stage 102 includes an array of switch 
elements 0 to L-1 (108a, 108n) . The third stage also 
includes an array of switch elements 0 to L-1 (112a, 112n) . 
5 Each switch element 108a, 108n has M physical input ports 
(or queues) 114 and N physical output ports 12 0 which route 
the incoming data to the next stage. Each third stage 
switch element 112a, 112n has N physical input ports (or 
queues) 118 and M physical output ports 122 which route the 

10 incoming data to an external node. Preferably, N is 

greater than M to ensure non-blocking capability of each 
switch element. The second stage includes an array of 
cross-connect elements 0 to N-1 (110a, llOn) . Each cross- 
connect element (110a, llOn) includes L physical port 

15 processors 116 each performing the space-domain switching. 
Space-domain switching is known to those skilled in the art 
of network switches and generally describes internal switch 
routing structure that allows connections between every 
input to every output . 

2 0 In one embodiment of the present invention, the 

credit -based adaptive flow control is applied between first 
stage 102 and second stage 104 to eliminate the 
conventional active bid-and-grant process. The credit- 
based adaptive flow control of the present invention will 

2 5 now be described in greater detail with reference to Figure 
2. 

Figure 2 illustrates the credit -based adaptive flow 
control logic 200 in the first stage ("Stage-1") 202 and 
second stage ("Stage-2") 204 of the present invention. In 

30 describing the present invention, the term "input element" 
will be used synonymously with an input port processor (114 
Figure 1) while the term "output element" used synonymously 
with an output port processor (12 0 Figure 1) . For example, 
elements 0 to M-1 of first stage refer to the port 

35 processors 0 to M-1 (114 Figure 1) of switch elements 0 to 
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L-1 (108a to 108n Figure 1) in the first stage as shown in 
Figure 1. Elements 0 to L-1 of second stage refer to port 
processors 0 to L-1 (116 Figure 1) of cross-connect 
elements 0 to N-1 (110a to llOn Figure 1) in the second 
5 stage. Similarly, input elements 0 to N-1 (118 Figure 1) 
of third stage refer to the input port processors 0 to M-1 
(122 Figure 1) of switch elements 0 to L-1 (112a to 112n 
Figure 1) in the third stage. 

Referring back to Figure 2, the first stage 202 

10 includes a plurality of first stage output elements, each 
of which plurality includes a threshold block 216 and an 
integrator block 206. The second stage 204 includes a 
plurality of second stage elements, each of which plurality 
includes a statistics block 208 corresponding to the 

15 threshold block 216/integrator block 206 in the first 
stage. Granti(O) shown at 230 for i=0,..., M-1, of the 
integrator block is the initial value of Grants (k) when 
time k is equal to 0. The value of Granti(O) 230 depends 
upon the switch latency of the second stage 204 and traffic 

20 class of an arriving data packet. Each integrator block 
206 of Stage-1 202 accumulates the grant tokens received 
from Stage-2 204 with the initial value grants (0) 230 as a 
starting point. Each integrator block 206 such as i-th 
integrator takes as input the logic values or token bits 

25 representing grant tokens from the corresponding statistics 
block 208, i.e., i-th block Stage-2, as well as from its 
neighboring blocks #(i-l) and #(i+l). 

As shown in Figure 2, each statistics block 208 of 
Stage-2 accumulates the number of arrivals and departures 

30 by incrementing the statistics counter 214 by 1 for each 

arrival and by decrementing the statistics counter by 1 for 
each departure. A statistics block may include a simple 
up/down counter 214 for incrementing a count when a packet 
arrives, and decrementing a count when the packet departs. 

35 The counter 214 may be coupled to a logic circuit 232 which 
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evaluates to "true" value when the counter 214 is 
incremented and then decremented for a particular packet 
arrival and departure. The "true" value triggers a token 
bit to be sent back to the first stage switch elements as 
5 shown. 

In the present invention, the second stage is 
bufferless, i.e., the second stage receives arriving data 
packets and transmits them to the third stage without 
storing or queuing the data packets in the second stage. 

10 The arrival and departure of data packets in the second 

stage are maintained by the second stage statistics block 
208. As described above, the second stage statistics block 
208 is arranged to accumulate the real-time statistics of 
data packet arrivals and departures. Every new arrival 224 

15 and departure 226, to and from i-th element of Stage-2 204 
triggers sending out a feedback token or a token bit, shown 
at 228, back to the i-th output element of Stage-1 202. 
When the new arrival departs Stage-2, the counter 214 is 
decremented by 1 as shown at 226. When a feedback token is 

20 triggered as a result of a new arrival, the grant credit of 
the i-th output element of Stage-1 is decreased by 1 while 
the grant credits of the (i-1) -th output element and (i+1) - 
th output element in Stage-1 are increased by 1. This 
unique adaptive filtering process effecting the credit- 

25 based adaptive flow control in a multi-stage multi- 
dimensional switching architecture is shown in Figure 2 by 
the arrows at 218, 220, 222 leading back to i-th, (i-1) -th, 
and (i+l) -th output elements in Stage-1, respectively. The 
arrow at 228 illustrates a logic value "a" as an example of 

3 0 a token bit being transmitted back to the first stage 
switch elements. 

With the above -de scribed method, statistics block 208 
(e.g., i-th element) updates the threshold block 216 via 
the integrator block 2 06 when data packets arrive and 

35 depart at Stage-2. The corresponding first stage 
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integrator block 206 (e.g., i-th output element) receives 
logic values or token bits from the statistic block 208 and 
updates grant credits. Briefly, grant credits represent 
the availability of a second stage element to receive an 
5 incoming data packet for routing. At the same time, the 
first stage integrator 23 6 that is above the corresponding 
first stage integrator 206 and the first stage integrator 
234 that is below the first stage integrator 206 receive 
logic values or token bits from the statistics block 208 

10 also and update their grant credits accordingly. When the 
filtering technique of the present invention described 
above is employed, the grant credits in the "threshold" 
blocks of the present invention converge to a nearly 
uniform probability distribution, and therefore the traffic 

15 between the first stage and second stage becomes balanced. 

Thus, in one embodiment of the present invention, a nearly 
uniform distribution probability is used as a reference in 
this adaptive "threshold" filtering technique. 

The operation of a "threshold" filtering of the 

2 0 present invention will now be described in greater detail 
herein below with reference to equations (1) to (7) . The 
i-th element among the plurality of processors in the 
switch architecture represents an element being considered, 
(i-l)-th element represents an element above the i-th 

25 element, and (i+1) -th element represents an element below 
the i-th element in the switch architecture. 

By using statistical information derived from the 
normal switching operation, the filtering process of the 
present invention estimates data flow and balances them in 

30 the multi-stage multi-dimensional data switch architecture 
without requiring specific information from the previous 
stage . 

When granti (k) = maximum among {grants (k) , i =0, 
N-l} and the packet is thus sent from the i-th output 
35 element of the first stage to the i-th element of Stage-2, 
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then the first stage does the following updates upon 
receiving the token bit from the second stage: 



granti (k+1) = grants {k)-l, (1) 

granti.;, (k+1) = grant^.i (k) -f 1 , (2) 

5 granti^i (k+l) = grant^^^ {k)+l, (3) 

i-0, . . , , N-1. 



The following two end conditions are maintained. 
For Upper Boundary, when granto(k) = maximum among 
10 {granti{k), i = 0, ,,,, N-l} and the packet is thus sent to 
the 0-th element of Stage-2, the first stage integrator 
blocks perform the following operations upon receiving the 
token bit from the second stage: 

granto(k+l) = granto(k)-l, (4) 
15 grant;^(k+l) = grants (k)+l. (5) 

For Bottom Boundary, when grantj^_3^ (k) = maximum among 
{granti(k)^ i=0,..., N-l} and the packet is thus sent to the 
(M-1) -th element of Stage-2, the first stage integrator 
20 blocks perform the following operations upon receiving the 
token bit from the second stage : 

grant^.i (k+1) = grant^.i (k) -1 , (6) 

grantM_2 (k+1) = grant^_2 (k) +1 . (7) 

25 In one embodiment of the present invention, the search 

for the maximum among {grants (k), i = 0, N-l} at each 

switch element of the first stage is performed in the 
ascending order from 0 to N-l, 

Figure 3 shows the upper boundary structure of the 

30 credit-based adaptive flow control logic. The integrator 
block #0 3 02 receives as input the logic values from the 
corresponding statistics block #0 305 of Stage-2 and its 
only neighboring block #1. The upper boundary grant credit 
update is shown by equations (4) and (5) . 

35 Figure 4 shows the bottom boundary structure of the 
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credit-based adaptive flow control logic. The detailed 
structure of the switch is the same as shown in Figure 2 
with the exception that the (N-l) -th integrator block 402 
receives as input the logic values from the corresponding 
5 statistics block #(N-1) 404 and its only neighboring block 
#(N-2) . The bottom boundary grant credit update is shown 
by equations (6) and (7) . 

Figure 5 is a diagram 500 illustrating a detailed 
internal structure and logic flow of a two-port first stage 

10 switch element. Each MxN port processors (114, 120 Figure 
1) of first stage includes an input port processor 502a, an 
output port processor 504a, and an integrator 206 and 
threshold 216 blocks 506a. The detailed logic flow of 
these devices was described herein above with reference to 

15 Figure 2. Generally, the data arriving at the input port 
processor 502a is routed to the second stage element via 
the output port processor 504a. In one embodiment, the 
data buffer 508, the routing matrix 510, and the routing 
control 512 is shared among the input and output port 

20 processors 502a, 502b, 504a, 504b, As shown, each output 
port processor {120 Figure 1) includes integrator and 
threshold blocks 506a, 506b coupled to the output port 
processors 504a, 504b. The detailed structure of the 
integrator and threshold block is shown at 506. The logic 

25 flow of the integrator and threshold block was described 
herein above with reference to Figure 2. 

Figure 6 is a diagram 600 illustrating a detailed 
internal structure and logic flow of a second stage 
CrossConnect element. Each L port processor (116 Figure 1) 

30 of second stage includes an input port processor 602a, an 
output port processor 604a, and a statistics block 606a. 
The detailed logic flow of these devices was described 
herein above with reference to Figure 2. Generally, when a 
data packet arrives at the input port processor 6 02a, the 

35 statistics block 606a increments an up/down counter 214 by 
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one. When the data packet is routed to the output port 
processor 604a or 604b via the routing control 610 and 
routing matrix 608, the statistics block 214 decrements its 
up/down counter by one. When the up/down counter 214 is 
5 greater than zero, it signifies a data arrival at the input 
port processor 602a; when the data packet departs at the 
output port processor 604a, a token bit is transmitted to 
corresponding and neighboring integrator blocks 206 of 
first stage elements. 

10 While the invention has been particularly shown and 

described with respect to an embodiment thereof, it will be 
understood by those skilled in the art that the foregoing 
and other changes in form and details may be made therein 
without departing from the spirit and scope of the 

15 invention. 
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CLAIMS 



What is claimed is: 

5 

1. A multi-stage, multi-dimensional, credit-based, 
adaptive flow control switch comprising: 

a plurality of first stage port processors, each one 
of the plurality of first stage port processors having an 

10 integrator block for receiving a token bit and updating a 
grant credit in response to receiving the token bit; and 

a plurality of second stage port processors connected 
to the plurality of first stage port processors for 
receiving data packets from the plurality of first stage 

15 port processors, each one of the plurality of second stage 
port processors having a statistics block coupled to a 
corresponding integrator block; 

the statistics block further coupled to one or more 
neighboring integrator blocks for transmitting a token bit 

20 to the corresponding integrator block and the one or more 
neighboring integrator blocks, the statistics block 
transmitting the token bit in response to a second stage 
port processor associated with the statistics block 
receiving a data packet from one of the plurality of the 

25 first stage port processors, 

2. The multi-stage, multi-dimensional, credit-based, 
adaptive flow control switch as claimed in claim 1, wherein 
the corresponding integrator block includes an (i)th 

3 0 integrator block and the one or more neighboring integrator 
blocks include an (i-l)th integrator block that is located 
above the corresponding (i)th integrator block, 

3. The multi-stage, multi -dimensional , credit-based, 
35 adaptive flow control switch as claimed in claim 2, wherein 
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the one or more neighboring integrator blocks further 
include an (i+l)th integrator block that is located below 
the corresponding (i)th integrator block. 



5 4. The multi-stage, multi-dimensional, credit-based, 

adaptive flow control switch as claimed in claim 3, wherein 
the one or more neighboring integrator blocks increase 
associated grant credits in response to receiving a token 
bit from the statistic block. 

10 

5. The multi-stage, multi-dimensional, credit-based, 
adaptive flow control switch as claimed in claim 4, wherein 
the corresponding integrator block decreases an associated 
grant credit in response to receiving a token bit from the 
15 statistic block. 

G. The multi-stage, multi -dimensional , credit-based, 
adaptive flow control switch as claimed in claim 5, wherein 
the plurality of first stage port processors includes one 
20 or more input ports and one or more output ports, wherein 
the arriving data packet is received at one of the one or 
more input ports and routed to an output port having a 
maximum number of grant credit . 

25 7. The multi-stage, multi -dimensional , credit -based, 

adaptive flow control switch as claimed in claim 1, wherein 
the switch further includes: 

a plurality of third stage port processors connected 
to the plurality of second stage port processors; and 

30 the statistic block further includes a real-time 

counter for accumulating real-time statistics of data 
packet arrivals from one of the plurality of first stage 
port processors and data packet departures to one of the 
plurality of third stage port processors. 
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8. The multi-stage, multi -dimensional, credit-based, 
adaptive flow control switch as claimed in claim 7, wherein 
the switch further includes a relay from each one of the 
third stage port processors to the plurality of first stage 

5 port processors, and the token bit is transmitted to the 
first stage port processors by one of second stage port 
processor and the third stage port processor. 

9. The multi-stage, multi -dimensional , credit-based, 
10 adaptive flow control switch as claimed in claim 8, wherein 

the plurality of first stage switch elements and the 
plurality of third stage switch elements are embedded on a 
single chip. 



15 10. An adaptive filtering method for controlling 

traffic flow in a multi-stage, multi-dimensional, switched 
network , compr i s ing : 

notifying a plurality of first stage port processors 
in response to receiving a data packet from one of the 

20 plurality of first stage port processors; and 

updating grant credits associated with said one of the 
plurality of first stage port processors and one or more 
neighboring first stage port processors in response to the 
notifying. 

25 

11. The adaptive filtering method of claim 10, 
wherein the notifying includes: 

notifying said one of the plurality of first stage 
port processors; and 
3 0 notifying said one or more neighboring first stage 

port processors. 



12. The adaptive filtering method of claim 11, 
wherein the updating grant credits includes: 
35 decrementing a grant credit associated with said one 
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of the plurality of first stage port processors; and 

incrementing one or more grant credits associated 
respectively with the one or more neighboring first stage 
port processors . 

5 

13. The adaptive filtering method of claim 12, 
further including: 

determining a port processor among the plurality of 
first stage port processors for forwarding an incoming data 
10 packet by selecting an output port processor having a 
maximum grant credit . 

14. The adaptive filtering method of claim 13, 
further including: 

15 receiving the incoming data packet at the determined 

port processor; and 

routing the data packet to a corresponding second 
stage port processor. 

20 15. The adaptive filtering method of claim 10, 

wherein the one or more neighboring first stage port 
processors include a first stage port processor coupled 
adjacent to said one of the plurality of first stage port 
processors . 

25 

16. The multi-stage, multi-dimensional, credit-based, 
adaptive flow control switch as claimed in claim 1, wherein 
the one or more neighboring integrator blocks change 
associated grant credits in response to receiving a token 

30 bit from the statistic block. 

17, The multi-stage, multi-dimensional, credit-based, 
adaptive flow control switch as claimed in claim 1, wherein 
the corresponding integrator block change an associated 

35 grant credit in response to receiving a token bit from the 
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statistic block. 

18, The multi-stage, multi-dimensional, credit-based, 
adaptive flow control switch as claimed in claim 1, wherein 
the statistics block departs the data packet. 
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CREDIT-BASED ADAPTIVE FLOW CONTROL FOR MULTI-STAGE MULTI- 
DIMENSIONAL SWITCHING ARCHITECTURE 

ABSTRACT OF THE INVENTION 

5 

The novel credit -based adaptive flow control method 
and system for multi-stage, multi -dimensional , data 
switching architecture. The method and system of the 
present invention estimates and balances data flow in the 

10 switch architecture by using statistical information 
derived from the normal switching operation without 
requiring specific information from the previous stage. 
The multi-stage multi -dimensional switching architecture of 
the present invention includes three stages. The first and 

15 third stages are the buffering stages, and the second stage 
acts as a buffer-less crossbar switch node. Each stage 
includes an array of switching elements, and each element 
includes either a queuing processor or an arbitration 
processor arranged to progressively refine estimates of the 

20 data traffic from switch elements in the first stage by the 
second stage. The second stage maintains the statistic of 
valid traffic arrival and departure, and feedback grant 
information bit to the first stage. The first stage treats 
every grant information as credit for each data departure 

25 to the second stage, and sends the data if there is a grant 
credit available. The adaptive filtering process adjusts a 
threshold adaptively, rendering the statistical properties 
to resemble a chosen probability distribution. 
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Figure 3 Upper Boundary of An Adaptive Credit-Based Flow Control Logic 
When Data Packet Arrives at Second-Stage From Output Pori#0 
of First-Stage 




Figure 4 Bottom Boundary of An Adaptive Crcdil-Bascd Flow Control Logic 
When Data Packet Arrives at Second-Stage From Output Port#N-l 
of First-Stage 
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